import Vue from 'vue'
import Vuex from 'vuex'
import creteState from 'vuex-persistedstate'

import axios from 'axios'

Vue.use(Vuex)

export default new Vuex.Store({
  plugins: [creteState()],
  state: {
    // 登录成功之后的token值
    token: '',
    userinfo: {}
  },
  mutations: {
    // 更新token 的mutation函数
    updateToken (state, newToken) {
      state.token = newToken
    },
    // 更新用户基本信息的mutation函数
    updateUserInfo (state, obj) {
      state.userinfo = obj
    }
  },
  actions: {
    // 调用接口,请求用户的基本信息
    // stx 就是new出来的store 的实例
    async initUserInfo (ctx) {
      const { data: res } = await axios.get('/my/userinfo')
      if (res.code === 0) {
        ctx.commit('updateUserInfo', res.data)
      }
    }
  },
  modules: {
  }
})
